]>
Commit | Line | Data |
---|---|---|
63a61ee2 BB |
1 | #region Using Statements |
2 | using System; | |
3 | using System.Collections.Generic; | |
4 | using Microsoft.Xna.Framework; | |
5 | using Microsoft.Xna.Framework.Content; | |
6 | using Microsoft.Xna.Framework.Graphics; | |
7 | using Microsoft.Xna.Framework.Input; | |
8 | using Microsoft.Xna.Framework.Storage; | |
9 | using Microsoft.Xna.Framework.GamerServices; | |
10 | using SuperPolarity; | |
11 | #endregion | |
12 | ||
13 | namespace SuperPolarity | |
14 | { | |
15 | /// <summary> | |
16 | /// This is the main type for your game | |
17 | /// </summary> | |
18 | public class SuperPolarity : Game | |
19 | { | |
95d7601b | 20 | public static GraphicsDeviceManager graphics; |
63a61ee2 BB |
21 | SpriteBatch spriteBatch; |
22 | ||
38c7d3f9 BB |
23 | public static int OutlierBounds; |
24 | ||
63a61ee2 BB |
25 | public SuperPolarity() |
26 | : base() | |
27 | { | |
95d7601b BB |
28 | SuperPolarity.graphics = new GraphicsDeviceManager(this); |
29 | SuperPolarity.graphics.PreferMultiSampling = true; | |
63a61ee2 | 30 | Content.RootDirectory = "Content"; |
2af83e98 | 31 | ActorFactory.SetGame(this); |
38c7d3f9 BB |
32 | ParticleEffectFactory.SetGame(this); |
33 | ActorManager.SetGame(this); | |
63a61ee2 BB |
34 | } |
35 | ||
36 | /// <summary> | |
37 | /// Allows the game to perform any initialization it needs to before starting to run. | |
38 | /// This is where it can query for any required services and load any non-graphic | |
39 | /// related content. Calling base.Initialize will enumerate through any components | |
40 | /// and initialize them as well. | |
41 | /// </summary> | |
42 | protected override void Initialize() | |
43 | { | |
63a61ee2 | 44 | base.Initialize(); |
2af83e98 | 45 | |
38c7d3f9 BB |
46 | OutlierBounds = 100; |
47 | ||
2af83e98 BB |
48 | InputController.RegisterEventForButton("changePolarity", Buttons.A); |
49 | InputController.RegisterEventForKey("changePolarity", Keys.Z); | |
50 | ||
51 | InputController.RegisterEventForButton("shoot", Buttons.X); | |
52 | InputController.RegisterEventForKey("shoot", Keys.X); | |
63a61ee2 BB |
53 | } |
54 | ||
55 | /// <summary> | |
56 | /// LoadContent will be called once per game and is the place to load | |
57 | /// all of your content. | |
58 | /// </summary> | |
59 | protected override void LoadContent() | |
60 | { | |
61 | // Create a new SpriteBatch, which can be used to draw textures. | |
62 | spriteBatch = new SpriteBatch(GraphicsDevice); | |
63 | ||
64 | Vector2 playerPosition = new Vector2(GraphicsDevice.Viewport.TitleSafeArea.X, GraphicsDevice.Viewport.TitleSafeArea.Y + GraphicsDevice.Viewport.TitleSafeArea.Height / 2); | |
65 | ||
38c7d3f9 BB |
66 | Renderer.CheckIn(ActorFactory.CreateMainShip(playerPosition)); |
67 | Renderer.CheckIn(ActorFactory.CreateShip(Ship.Polarity.Positive, new Vector2(200, 200))); | |
68 | Renderer.CheckIn(ActorFactory.CreateShip(Ship.Polarity.Negative, new Vector2(400, 200))); | |
63a61ee2 BB |
69 | } |
70 | ||
71 | /// <summary> | |
72 | /// UnloadContent will be called once per game and is the place to unload | |
73 | /// all content. | |
74 | /// </summary> | |
75 | protected override void UnloadContent() | |
76 | { | |
77 | // TODO: Unload any non ContentManager content here | |
78 | } | |
79 | ||
80 | /// <summary> | |
81 | /// Allows the game to run logic such as updating the world, | |
82 | /// checking for collisions, gathering input, and playing audio. | |
83 | /// </summary> | |
84 | /// <param name="gameTime">Provides a snapshot of timing values.</param> | |
85 | protected override void Update(GameTime gameTime) | |
86 | { | |
87 | if (GamePad.GetState(PlayerIndex.One).Buttons.Back == ButtonState.Pressed || Keyboard.GetState().IsKeyDown(Keys.Escape)) | |
88 | Exit(); | |
89 | ||
90 | // TODO: Add your update logic here | |
91 | ||
95d7601b | 92 | InputController.UpdateInput(); |
f8aec187 | 93 | ActorManager.Update(gameTime); |
95d7601b | 94 | |
63a61ee2 BB |
95 | base.Update(gameTime); |
96 | } | |
97 | ||
98 | /// <summary> | |
99 | /// This is called when the game should draw itself. | |
100 | /// </summary> | |
101 | /// <param name="gameTime">Provides a snapshot of timing values.</param> | |
102 | protected override void Draw(GameTime gameTime) | |
103 | { | |
95d7601b | 104 | GraphicsDevice.Clear(Color.White); |
63a61ee2 BB |
105 | |
106 | spriteBatch.Begin(); | |
107 | ||
38c7d3f9 | 108 | Renderer.Draw(spriteBatch); |
63a61ee2 BB |
109 | |
110 | spriteBatch.End(); | |
111 | ||
112 | base.Draw(gameTime); | |
113 | } | |
114 | } | |
115 | } |